javascript - 初始化一个javascript数组
全部标签 我正在尝试使用我的2Druby数组解决一些问题,当我进行数组切片时,我的LOC减少了很多。例如,require"test/unit"classLibraryTest我想知道是否有办法得到对角切片?假设我想从[0,0]开始并想要一个3的对角线切片。然后我会从[0,0]、[1,1]、[2,2]获取元素,我会得到一个数组[1,4,7]上面的例子。是否有任何神奇的单行ruby代码可以实现这一目标?3.次做{一些神奇的东西?} 最佳答案 puts(0..2).collect{|i|array[i][i]}
如果array=[1,2,3,4,5,6,7,8,9],我想从数组中删除一系列元素。例如:我想从该数组中删除索引在2..5范围内的所有元素,结果应该是[1,2,7,8,9]提前致谢。 最佳答案 使用slice!:Deletestheelement(s)givenby[...]arange.array=[1,2,3,4,5,6,7,8,9]array.slice!(2..5)array#=>[1,2,7,8,9] 关于ruby-如何从数组中删除一系列值?,我们在StackOverflow上
总结:这里的基本问题是,我发现,您是否可以将代码块传递给Ruby数组,这实际上会将该数组的内容减少到另一个数组,而不是单个值(inject的方式)。最简洁的答案是不”。我接受这样的回答。感谢Squeegy提供了一个很好的循环策略来从数组中去除条纹。挑战:在不显式循环遍历数组的情况下减少数组的元素。输入:所有从-10到10(0除外)的整数随机排列。TheDesiredOutput:一个表示正数或负数条纹的数组。例如,-3表示三个连续的负数。2代表两个连续的正数。示例脚本:original_array=(-10..10).to_a.sort{rand(3)-1}original_array
生成具有固定距离的值的数组的简单方法是什么?例如:1,4,7,10,...etc我需要能够设置开始、结束和步距。 最佳答案 尝试使用Range.step:>(1..19).step(3).to_a=>[1,4,7,10,13,16,19] 关于ruby-创建具有均匀间隔值的数组,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/4838381/
这是我现在所拥有的,它有点管用:defpadding(a,b,c=nil)untila[b-1]a这是它起作用的时候:a=[1,2,3]padding(a,10,"YES")=>[1,2,3,"YES","YES","YES","YES","YES","YES","YES"]a[1,2,3]padding(a,10,1)=>[1,2,3,1,1,1,1,1,1,1]但是当我没有为“c”输入值时它崩溃了a=[1,2,3]padding(a,10)Killed我应该如何附加它以避免崩溃?此外,您建议如何更改此方法以按如下方式使用它:[1,2,3].padding(10)=>[1,2,3,n
我需要一个散列,其键的默认值应为0。(基本上我正在制作一个计数器)。key未知,所以我无法在开始时初始化它们。同样,每次出现该键时,该值都应增加1。我想出了这个:hash={}hash[key]?hash[key]+=1:hash[key]=0这看起来不错而且简短,但我不喜欢在一行代码中重复多次hash[key]。有没有更好的写法? 最佳答案 我想你只需要给散列一个默认值0hash=Hash.new(0)然后对于每次出现的键,你不需要检查它的值,直接增加它:hash[key]+=1引用:Hash#new.
我在这里冒着手掌到额头的风险,但我不太清楚如何使用Rails的ActiveRecord糖来做到这一点。我有一个tickets表,它有两列(submitter_id和assignee_id),每列都应该引用来自的不同用户users表(特别是users表中的id列)。我希望能够使用ActiveRecord的关联来执行诸如ticket.submitter.name和ticket.assignee.email之类的事情。提交者和受让人只是不同关联名称下的用户对象。我发现的唯一接近我正在做的事情是使用多态关联,但最后我相当确定这不是我真正需要的。我不会有多种类型,提交者和受让人都是用户,很可能是
最好的方法是:我有两个数组:a=[['a','one'],['b','two'],['c','three'],['d','four']]和b=['two','three']我想删除a中包含b中的元素的嵌套数组,得到这个:[['a','one']['d','four']谢谢。 最佳答案 a=[['a','one'],['b','two'],['c','three'],['d','four']]b=['two','three']a.delete_if{|x|b.include?(x.last)}pa#=>[["a","one"],["d
如何使用数组中的键初始化散列,如下所示?keys=['a','b','c']所需的哈希h应该是:putsh#{'a'=>nil,'b'=>nil,'c'=>nil} 最佳答案 这里我们使用Enumerable#each_with_object和Hash::[].keys=['a','b','c']Hash[keys.each_with_object(nil).to_a]#=>{"a"=>nil,"b"=>nil,"c"=>nil}或使用Array#productkeys=['a','b','c']Hash[keys.product(
...或者一个防止重复条目的数组。Ruby中是否有某种对象:响应[]、[]=和默默地删除重复的条目是可枚举的(或至少支持find_all)保留条目插入的顺序?据我所知,数组支持点1、3和4;而Set支持1、2和3(但不支持4)。而SortedSet不会做,因为我的条目没有实现。 最佳答案 从Ruby1.9开始,内置的Hash对象保留了插入顺序。例如:h={}h[:z]=1h[:b]=2h[:a]=3h[:x]=0ph.keys#=>[:z,:b,:a,:x]h.delete:bph.keys#=>[:z,:a,:x]h[:b]=1p